﻿<!DOCTYPE html>
<html>
<head>
    <meta charset="utf-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <title>员工管理</title>
    <#include "/common/link.ftl">

</head>
<body class="hold-transition skin-black sidebar-mini">
<div class="wrapper">
    <#include "/common/navbar.ftl">
    <!--菜单回显-->
    <#assign currentMenu="employee"/>
    <#include "/common/menu.ftl">
    <div class="content-wrapper">
        <section class="content-header">
            <h1>员工编辑</h1>
        </section>
        <section class="content">
            <div class="box">
                <form class="form-horizontal"  method="post" id="editForm" >
                    <input type="hidden" name="id" value="${employee.id}">
                    <div class="form-group" style="margin-top: 10px;">
                        <label class="col-sm-2 control-label">用户名：</label>
                        <div class="col-sm-6">
                            <input type="text" class="form-control" name="username"  placeholder="请输入用户名"  ${(employee??)?string('disabled','')} value="${employee.username}">
                        </div>
                    </div>
                    <div class="form-group" style="margin-top: 10px;">
                        <label class="col-sm-2 control-label">真实姓名：</label>
                        <div class="col-sm-6">
                            <input type="text" class="form-control" name="name"  placeholder="请输入真实姓名" value="${employee.name}">
                        </div>
                    </div>
                    <#if !employee??>
                    <div class="form-group">
                        <label for="password" class="col-sm-2 control-label">密码：</label>
                        <div class="col-sm-6">
                            <input type="password" class="form-control" id="password" name="password" placeholder="请输入密码" value="${employee.password}">
                        </div>
                    </div>
                    <div class="form-group">
                        <label for="repassword" class="col-sm-2 control-label">验证密码：</label>
                        <div class="col-sm-6">
                            <input type="password" class="form-control" id="repassword" name="repassword" placeholder="再输入一遍密码" value="${employee.password}">
                        </div>
                    </div>
                    </#if>
                    <div class="form-group">
                        <label for="email" class="col-sm-2 control-label">电子邮箱：</label>
                        <div class="col-sm-6">
                            <input type="text" class="form-control"  name="email" placeholder="请输入邮箱" value="${employee.email}">
                        </div>
                    </div>
                    <div class="form-group">
                        <label for="age" class="col-sm-2 control-label">年龄：</label>
                        <div class="col-sm-6">
                            <input type="text" class="form-control" name="age" placeholder="请输入年龄" value="${employee.age}">
                        </div>
                    </div>
                    <div class="form-group">
                        <label for="dept" class="col-sm-2 control-label">部门：</label>
                        <div class="col-sm-6">
                            <select class="form-control" id="dept" name="dept.id">
                                <option value="">全部</option>
                              <#list departments as department>
                                  <option value="${department.id}" ${(employee.dept.id==department.id)?string('selected','')}>${department.name}</option>
                              </#list>
                            </select>
                        </div>
                    </div>
                    <div class="form-group" id="adminDiv">
                        <label for="admin" class="col-sm-2 control-label">超级管理员：</label>
                        <div class="col-sm-6"style="margin-left: 15px;">
                            <input type="checkbox" id="admin" name="admin" class="checkbox" ${(employee.admin==true)?string('checked','')}>
                        </div>
                    </div>
                    <script>
                        var $save ;
                            $('#admin').click(function () {
                                var checked =$(this).prop('checked');
                                if (checked){
                                    $save = $('#roleDiv').remove() ;
                                }else {
                                    $('#adminDiv').after($save) ;
                                }
                        })

                        $(function () {
                            var checked = $('#admin').prop('checked');
                            if (checked){
                                $save = $('#roleDiv').remove() ;
                            }
                        })
                    </script>
                    <div class="form-group" id="roleDiv">
                        <label for="role" class="col-sm-2 control-label">分配角色：</label><br/>
                        <div class="row" style="margin-top: 10px">
                            <div class="col-sm-2 col-sm-offset-2">
                                <select multiple class="form-control allRoles" style="height: 350px;" size="15">
                                    <#list roles as role>
                                        <option value="${role.id}">${role.name}</option>
                                   </#list>
                                </select>
                            </div>

                            <div class="col-sm-1" style="margin-top: 60px;" align="center">
                                <div>

                                    <a type="button" class="btn btn-primary  " style="margin-top: 10px" title="右移动"
                                       onclick="moveSelected('allRoles', 'selfRoles')">
                                        <span class="glyphicon glyphicon-menu-right"></span>
                                    </a>
                                </div>
                                <div>
                                    <a type="button" class="btn btn-primary " style="margin-top: 10px" title="左移动"
                                       onclick="moveSelected('selfRoles', 'allRoles')">
                                        <span class="glyphicon glyphicon-menu-left"></span>
                                    </a>
                                </div>
                                <div>
                                    <a type="button" class="btn btn-primary " style="margin-top: 10px" title="全右移动"
                                       onclick="moveAll('allRoles', 'selfRoles')">
                                        <span class="glyphicon glyphicon-forward"></span>
                                    </a>
                                </div>
                                <div>
                                    <a type="button" class="btn btn-primary " style="margin-top: 10px" title="全左移动"
                                       onclick="moveAll('selfRoles', 'allRoles')">
                                        <span class="glyphicon glyphicon-backward"></span>
                                    </a>
                                </div>
                            </div>
                            <div class="col-sm-2">
                                <select multiple class="form-control selfRoles" style="height: 350px;" size="15" name="ids">
                                    <#list ownRoles as role>
                                        <option value="${role.id}">${role.name}</option>
                                    </#list>
                                </select>
                            </div>
                        </div>
                    </div>
                    <script>
                        function moveAll(prevClass ,targetClass) {
                            $('.'+targetClass).append($('.'+prevClass+'>option'))
                        }

                        function moveSelected(prevClass ,targetClass) {
                            $('.'+targetClass).append($('.'+prevClass+'>option:selected'))
                        }

                        $(function () {
                            var vals = [] ;
                            $('.selfRoles>option').each(function (index,domEle) {
                                var $dom = $(domEle);
                                var val = $dom.val();
                                vals.push(val);
                            });

                            $('.allRoles>option').each(function (index,domEle) {
                                var $dom = $(domEle);
                                var val = $dom.val();
                                if ($.inArray(val, vals) >= 0) {
                                    $dom.remove()
                                }
                            })
                        })

                    </script>
                    <div class="form-group">
                        <div class="col-sm-offset-1 col-sm-6">
                            <button type="submit" class="btn btn-primary btn-submit">保存</button>
                            <a href="javascript:window.history.back()" class="btn btn-danger">取消</a>
                        </div>
                    </div>
                    <script>
                        $("#editForm").bootstrapValidator({
                            feedbackIcons: { // 图标
                                valid: 'glyphicon glyphicon-ok',
                                invalid: 'glyphicon glyphicon-remove',
                                validating: 'glyphicon glyphicon-refresh'
                            },
                            fields:{ // 配置要验证的字段
                                username:{
                                    validators:{ // 验证的规则
                                        notEmpty:{ // 不能为空
                                            message:"用户名必填" // 错误时的提示信息
                                        },
                                        stringLength: { // 字符串的长度范围
                                            min: 1,
                                            max: 5
                                        },
                                        remote: { // 远程验证
                                            type: 'post', // 请求方式
                                            url: '/employee/checkUserName', // 请求地址
                                            message: '用户名已经存在', // 验证不通过时的提示信息
                                            delay: 1000, // 输入内容 1 秒后发请求
                                            /* data: function() {   //自定义提交的参数，默认只会提交当前用户名 input 的参数
                                                          return {
                                                              username: $('[name="username"]').val()
                                                          };
                                                      }*/
                                        }
                                    }
                                },
                                name:{
                                    validators:{ // 验证的规则
                                        notEmpty:{ // 不能为空
                                            message:"姓名必填" // 错误时的提示信息
                                        },
                                        stringLength: { // 字符串的长度范围
                                            min: 1,
                                            max: 5
                                        }
                                    }
                                },
                                password:{
                                    validators:{
                                        notEmpty:{ // 不能为空
                                            message:"密码必填" // 错误时的提示信息
                                        },
                                    }
                                },
                                repassword:{
                                    validators:{
                                        notEmpty:{ // 不能为空
                                            message:"密码必填" // 错误时的提示信息
                                        },
                                        identical: {// 两个字段的值必须相同
                                            field: 'password',
                                            message: '两次输入的密码必须相同'
                                        },
                                    }
                                },
                                email: {
                                    validators: {
                                        emailAddress: {} // 邮箱格式
                                    }
                                },
                                age:{
                                    validators: {
                                        between: { // 数字的范围
                                            min: 18,
                                            max: 60
                                        }
                                    }
                                }
                            }
                        }).on('success.form.bv', function(e) {
                            //阻止表单提交
                            e.preventDefault();

                            var $form = $(e.target);
                            $('.selfRoles > option').prop('selected', 'true');
                            // 发送请求
                            $.post('/employee/save', $form.serialize(),function (data) {
                                if(data.success){
                                    Swal.fire(data.msg)
                                    setTimeout(()=>location.href = '/employee/list',1000) ;
                                }else {
                                    Swal.fire(data.msg)
                                }
                            })
                        });
                    </script>
                </form>

            </div>
        </section>
    </div>
    <#include "/common/footer.ftl">
</div>
</body>
</html>
